package com.ovidiojf.vendas.produto;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.classic.Session;

public class ProdutoDAOHibernate implements ProdutoDAO {
	
	private Session session;

	public Session getSession() {
		return session;
	}

	public void setSession(Session session) {
		this.session = session;
	}

	@Override
	public void salvar(Produto produto) {
		this.session.save(produto); 
		
	}

	@Override
	public void excluir(Produto produto) {
		this.session.delete(produto);
		
	}

	@SuppressWarnings("unchecked")
	@Override
	public List<Produto> listar() {
		Criteria lista = session.createCriteria(Produto.class);
		return lista.list();
	}

	@Override
	public Produto pesquisarPorDescricao(String descricao) {

		String sql = "from Produto p where p.descricao like :descricao";
		Query consulta = session.createQuery(sql);
		consulta.setString("descricao", "%"+descricao+"%");
		return (Produto) consulta.uniqueResult();	
	}

}
